

8 61 4

bit

X31

64 bit

## **Store Instruction**

- The STUR instruction tells the CPU to store (copy) the contents of CPU register to a memory location pointed by destination register.
- Since the CPU registers are 64 bit (8 byte) wide, we need 8 consecutive memory locations to store the contents of the register.



7 64 bit

**Example:** Convert the following C++ code to LEGv8 Assembly code. Assume A is an Array of 10 doublewords, variable h is associated with register X21, and base address of the array A is in X22.

$$A [2] = h + A [1];$$

$$\times 2$$

X22- AC) AC2) X22- AC) AC2)

$$11 \quad X9 = A \quad Ci)$$

$$11 \quad X9 = h + A \quad Ci)$$

## Representing Instructions in the computer (Translating a LEGV8 assembly instruction into a Machine instruction)

Instruction Format: The layout of an instruction is called the instruction format. LEGv8 instructions are 32 bit long.

| Instruction          | Format | opcode              | Rm  | shamt | address  | op2  | En  | Rd   |
|----------------------|--------|---------------------|-----|-------|----------|------|-----|------|
| · ADD (add)          | R      | 1112 <sub>ten</sub> | reg | 0     | n.a.     | n.a. | reg | reg  |
| SUB (subtract)       | R      | 1624 <sub>ten</sub> | reg | 0     | n.a.     | n.a. | reg | reg  |
| ADDI (add immediate) | 800000 | _580 <sub>ten</sub> | reg | n.a.  | constant | n.a. | reg | n.a. |
| SUBI (sub immediate) | -      | 836 <sub>ten</sub>  | reg | n.a.  | constant | n.a. | reg | n.a. |
| LDUR (load word)     | D ,    | 1986 <sub>ten</sub> | reg | n.a.  | address  | 0    | reg | n.a. |
| STUR (store word)    | D -    | 1984 <sub>ten</sub> | reg | n.a.  | address  | 0    | reg | n.a. |

LEGV8 R-Format Instructions:

| nat Instructions: | ×9 | X 50 | XFI |
|-------------------|----|------|-----|
|                   |    |      |     |

| opcode  | Rm     | shamt  | Rn     | Rd     |
|---------|--------|--------|--------|--------|
| 11 bits | 5 bits | б bits | 5 bits | 5 bits |

|   | OPCORE; | X9, X2 | Rn code  | Rm.       |
|---|---------|--------|----------|-----------|
| - | Rn :    | Obenu  |          | a 1       |
|   | Shamt : | shift  | ameunt   | 0)        |
|   | Rn:     | 8 Pera | ~& 1     | 2 paisten |
| - | Rd      | . D63, | tination | Registen  |

Translate the following LEGV8 assembly instruction into a machine instruction:

ADD X9, X20, X21



## 1986 -> 1/1/1 000010

LDUR STUR.

## **LEGv8 D-Format Instructions:**

| _       |         |        |        |        |
|---------|---------|--------|--------|--------|
| opcode  | address | op2    | Rn     | D+     |
| 11 bits | 9 bits  | 2 bits | 5 bits | 513    |
|         |         |        | Jons   | 5 bits |

Rn: Buje Register

address: Constant offset

Rt : destination (load) or source (store) register

Translate the following LEGV8 assembly instruction into a machine

LDUR X9, [X10, #8]

Decimal 1986 8 ()10 11 9

Hex value: #840814916